<!DOCTYPE html>
<html xmlns:th="http://www.thymeleaf.org"
	  xmlns:shiro="http://www.pollix.at/thymeleaf/shiro">
<head>
	<meta charset="UTF-8">
	<title>学生管理</title>
	<meta name="renderer" content="webkit">
	<meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
	<meta http-equiv="Access-Control-Allow-Origin" content="*">
	<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">
	<meta name="apple-mobile-web-app-status-bar-style" content="black">
	<meta name="apple-mobile-web-app-capable" content="yes">
	<meta name="format-detection" content="telephone=no">
	<link rel="icon" href="/favicon.ico">
	<link rel="stylesheet" href="/resources/layui/css/layui.css" media="all" />
	<link rel="stylesheet" href="/resources/css/public.css" media="all" />
	<link rel="stylesheet" href="/resources/layui_ext/dtree/dtree.css" media="all" />
	<link rel="stylesheet" href="/resources/layui_ext/dtree/font/dtreefont.css" media="all" />

</head>
<body class="childrenBody">
<!-- 查询条件开始 -->
<fieldset class="table-search-fieldset" style="padding-top: 15px;">
	<legend>查询条件</legend>
	<form action="" method="post" id="searchFrm" lay-filter="searchFrm" class="layui-form layui-form-pane">
		<div class="layui-form-item">
			<div class="layui-inline">
				<label class="layui-form-label">所属学院</label>
				<div class="layui-input-inline">
					<input type="hidden" name="deptid" id="search_deptid">
					<ul id="search_deptTree" class="dtree" data-id="0"></ul>
				</div>
			</div>
			<div class="layui-inline">
				<label class="layui-form-label">学生姓名</label>
				<div class="layui-input-inline">
					<input type="text" name="name" autocomplete="off" class="layui-input">
				</div>
			</div>
			<div class="layui-inline" style="text-align: center;">
				<button type="button" class="layui-btn layui-btn-primary" lay-submit="" lay-filter="doSearch"><span
						class="layui-icon layui-icon-search"></span>查询
				</button>
				<button type="reset" onclick="javascript:document.getElementById('search_deptid').value=''"
						class="layui-btn layui-btn-primary"><span
						class="layui-icon layui-icon-refresh-1"></span>重置
				</button>
			</div>
		</div>
	</form>
</fieldset>
<!-- 查询条件结束-->


<!-- 数据表格开始 -->
<div>
	<table class="layui-hide" id="userTable" lay-filter="userTable"></table>
	<div id="userToolBar" style="display: none;">
		<button type="button" lay-event="add" class="layui-btn layui-btn-normal layui-btn-sm"><span class="layui-icon layui-icon-add-1"></span>添加学生</button>
	</div>

	<div id="userRowBar" style="display: none;">
		<button type="button" lay-event="update" class="layui-btn layui-btn-normal layui-btn-sm"><span class="layui-icon layui-icon-edit"></span>更新</button>
		<button type="button" lay-event="delete" class="layui-btn layui-btn-sm layui-btn-danger"><span class="layui-icon layui-icon-delete"></span>删除</button>
		<button type="button" lay-event="resetPwd" class="layui-btn layui-btn-sm"><span class="layui-icon layui-icon-edit"></span>重置密码</button>
	</div>
</div>

<!-- 数据表格结束 -->

<!-- 添加和修改的弹出层开始 -->
<div style="display: none;padding-right: 20px;" class="layui-form layuimini-form" id="addOrUpdateDiv">
	<form action="" method="post" class="layui-form" id="dataFrm" lay-filter="dataFrm">
		<div class="layui-form-item"></div>
		<div class="layui-form-item">
			<div class="layui-inline">
				<label class="layui-form-label">所属学院</label>
				<div class="layui-input-inline">
					<input type="hidden" name="deptid" id="deptid">
					<ul id="deptTree" class="dtree" data-id="0"></ul>
				</div>
			</div>
			<div class="layui-inline">
				<label class="layui-form-label">排序码</label>
				<div class="layui-input-inline">
					<input type="hidden" name="id">
					<input type="text" name="ordernum" id="ordernum" lay-verify="required|number"  autocomplete="off" placeholder="请输入排序码[>0]" class="layui-input">
				</div>
			</div>
		</div>
		<div class="layui-form-item">
			<div class="layui-inline">
				<label class="layui-form-label">所在班级</label>
				<div class="layui-input-inline">
					<ul id="classesdeptTree" class="dtree" data-id="0"></ul>
				</div>
			</div>
			<div class="layui-inline">
				<label class="layui-form-label">班主任</label>
				<div class="layui-input-inline">
					<select name="mgr" id="mgr">
						<option value="1" disabled="disabled">请选择班主任</option>
					</select>
				</div>
			</div>
		</div>
		<div class="layui-form-item">
			<div class="layui-inline">
				<label class="layui-form-label">学生姓名</label>
				<div class="layui-input-inline">
					<input type="text" name="name" id="username" lay-verify="required" autocomplete="off" placeholder="请输入学生姓名" class="layui-input">
				</div>
			</div>
			<div class="layui-inline">
				<label class="layui-form-label">登陆名称</label>
				<div class="layui-input-inline">
					<input type="text" name="loginname" id="loginname" lay-verify="required"  autocomplete="off" placeholder="请输入登陆名称" class="layui-input">
				</div>
			</div>
		</div>
		<div class="layui-form-item">
			<div class="layui-inline">
				<label class="layui-form-label">联系方式</label>
				<div class="layui-input-inline">
					<input type="text" name="phone" autocomplete="off" placeholder="请输入联系方式" class="layui-input">
				</div>
			</div>
			<div class="layui-inline">
				<label class="layui-form-label">学生性别</label>
				<div class="layui-input-inline">
					<input type="radio" name="sex" value="1" title="男" checked="">
					<input type="radio" name="sex" value="0" title="女" >
				</div>
			</div>
		</div>
		<div class="layui-form-item">
			<label class="layui-form-label">学生地址</label>
			<div class="layui-input-block">
				<input type="text" name="address"  autocomplete="off" placeholder="请输入学生地址" class="layui-input">
			</div>
		</div>
		<div class="layui-form-item">
			<div class="layui-inline">
				<label class="layui-form-label">是否可用</label>
				<div class="layui-input-inline">
					<input type="radio" name="available" value="1" title="可用" checked="">
					<input type="radio" name="available" value="0" title="不可用" >
				</div>
			</div>
		</div>
		<div class="layui-form-item">
			<div class="layui-input-block">
				<button type="button" class="layui-btn layui-btn-normal" lay-submit="" lay-filter="doSubmit" ><span class="layui-icon layui-icon-add-1"></span>提交</button>
				<button type="reset" onclick="javascript:document.getElementById('deptid').value=''" class="layui-btn layui-btn-normal"><span class="layui-icon layui-icon-refresh-1"></span>重置</button>
			</div>
		</div>
	</form>
</div>
<!-- 添加和修改的弹出层结束 -->


<!-- 学生分配角色弹出层  开始 -->
<div style="display: none;padding: 5px" id="selectUserRoleDiv">
	<table class="layui-hide" id="roleTable" lay-filter="roleTable"></table>
</div>


<!-- 学生分配角色弹出层  结束 -->


<script type="text/javascript" src="/resources/layui/layui.js"></script>
<script type="text/javascript">
	var tableIns;
	layui.extend({
		dtree: '/resources/layui_ext/dtree/dtree'   // {/}的意思即代表采用自有路径，即不跟随 base 路径
	}).use(['jquery','form','table','layer','dtree'],function(){
		var $=layui.jquery;
		var form=layui.form;
		var table=layui.table;
		var layer=layui.layer;
		var dtree=layui.dtree;
		//加载数据
		tableIns=table.render({
			elem: '#userTable'
			,url:'/user/loadAllUser?type=5'
			,toolbar: '#userToolBar' //开启头部工具栏，并为其绑定左侧模板
			,title: '学生数据表'
			,page: true
			,cols: [ [
				{field:'id', title:'ID',align:'center',width:'80'}
				,{field:'name', title:'学生姓名',align:'center',width:'100'}
				,{field:'loginname', title:'登陆名称',align:'center',width:'100'}
				,{field:'sex', title:'性别',align:'center',width:'80',templet:function(d){
						return d.sex==1?'<font color=blue>男</font>':'<font color=red>女</font>';
					}}
				,{field:'deptname', title:'所属学院',align:'center',width:'120'}
				,{field:'classes', title:'所在班级',align:'center',width:'120'}
				,{field:'leadername', title:'班主任',align:'center',width:'100'}
				,{field:'address', title:'学生地址',align:'center',width:'150'}
				,{field:'phone', title:'联系方式',align:'center',width:'150'}
				,{field:'hiredate', title:'入学时间',align:'center',width:'180'}
				,{field:'available', title:'是否可用',align:'center',width:'100',templet:function(d){
						return d.available==1?'<font color=blue>可用</font>':'<font color=red>不可用</font>';
					}}
				,{field:'ordernum', title:'排序码',align:'center',width:'100'}
				,{fixed: 'right', title:'操作', toolbar: '#userRowBar',align:'center',width:'280'}
			] ]
			,done: function(res, curr, count){ //处理删除某一页最后一条数据的BUG
				if(res.data.length==0&&curr!=1){
					tableIns.reload({
						page:{
							curr:(curr-1)
						}
					});
				}
			}
		});

		//模糊查询
		form.on("submit(doSearch)",function(data){
			tableIns.reload({
				where:data.field,
				page:{
					curr:1
				}
			});
			return false;
		});

		//监听工具条的事件
		table.on("toolbar(userTable)",function(obj){
			switch(obj.event){
				case 'add':
					openAddLayer();
					break;
			};
		});

		//监听行工具条的事件
		table.on("tool(userTable)",function(obj){
			var data = obj.data; //获得当前行数据
			switch(obj.event){
				case 'update':
					openUpdateUserLayer(data);
					break;
				case 'delete':
					deleteUser(data);
					break;
				case 'resetPwd':
					resetPwd(data);
					break;
			};
		});

		var mainIndex;
		var url;
		//打开添加的弹出层
		function openAddLayer(){
			mainIndex=layer.open({
				type:1,
				content:$("#addOrUpdateDiv"),
				area:['800px','600px'],
				title:'添加学生',
				success:function(){
					$("#dataFrm")[0].reset();
					$("#deptid").val("");
					url="/user/addUser?type=5";
					//初始化排序码
					$.get("/user/loadUserMaxOrderNum",function(res){
						$("#ordernum").val(res.value);
					});
					var html="<option value='1' disabled='disabled'>请选择班主任</option>";
					$("#mgr").html(html);
					form.render("select");
				}
			});
		}

		//打开修改的弹出层
		function openUpdateUserLayer(data){
			mainIndex=layer.open({
				type:1,
				content:$("#addOrUpdateDiv"),
				area:['800px','600px'],
				title:'修改学生',
				success:function(){
					$("#dataFrm")[0].reset();
					$("#deptid").val("");
					//装载新的数据
					form.val("dataFrm",data);
					//选中之前的所属学院  nodeId=data.deptid;
					dtree.dataInit("deptTree", data.deptid);
					dtree.setSelectValue("deptTree");

					//选中所在班级
					var leaderid=data.mgr;
					$.get("/user/loadUserById",{id:leaderid},function(res){
						var d=res.data;
						dtree.dataInit("classesdeptTree", d.deptid);
						dtree.setSelectValue("classesdeptTree");
						$.get("/user/loadUsersByDeptId?type=4",{deptid:d.deptid},function(res){
							var users=res.data;
							var dom_mgr=$("#mgr");
							var html="<option value='1' disabled='disabled'>请选择班主任</option>";
							$.each(users,function(index,item){
								html+="<option value='"+item.id+"'>"+item.name+"</option>";
							});
							dom_mgr.html(html);
							//选中一个
							dom_mgr.val(leaderid);
							//重新渲染
							form.render("select");
						});
					})
					url="/user/updateUser";
				}
			});
		}
		form.on("submit(doSubmit)",function(data){
			$.post(url,data.field,function(res){
				if(res.code==200){
					tableIns.reload();
				}
				layer.msg(res.msg);
				layer.close(mainIndex);
			})
			return false;
		})
		//删除
		function deleteUser(data){
			layer.confirm('你确定要删除【'+data.name+'】这位学生吗?', {icon: 3, title:'提示'}, function(index){
				$.post("/user/deleteUser",{id:data.id},function(res){
					if(res.code==200){
						tableIns.reload();
					}
					layer.msg(res.msg);
				})
				layer.close(index);
			});
		}


		//重置密码
		function resetPwd(data){
			layer.confirm('你确定要重置【'+data.name+'】这位学生密码吗?', {icon: 3, title:'提示'}, function(index){
				$.post("/user/resetPwd",{id:data.id},function(res){
					layer.msg(res.msg);
				})
				layer.close(index);
			});
		}

		//初始化查询条件下拉树
		var search_deptTree=dtree.renderSelect({
			elem: "#search_deptTree",
			width: "100%", // 可以在这里指定树的宽度来填满div
			dataStyle: "layuiStyle",  //使用layui风格的数据格式
			dataFormat: "list",  //配置data的风格为list
			response:{message:"msg",statusCode:0},  //修改response中返回数据的定义
			url: "/dept/loadDeptManagerLeftTreeJson" // 使用url加载（可与data加载同时存在）
		});
		//监听点击的方法
		dtree.on("node(search_deptTree)" ,function(obj){
			$("#search_deptid").val(obj.param.nodeId);
			console.log(obj.param.nodeId); // 点击当前节点传递的参数
		});

		//初始化添加弹出层所属学院的下拉列表
		var deptTree=dtree.renderSelect({
			elem: "#deptTree",
			width: "100%", // 可以在这里指定树的宽度来填满div
			dataStyle: "layuiStyle",  //使用layui风格的数据格式
			dataFormat: "list",  //配置data的风格为list
			response:{message:"msg",statusCode:0},  //修改response中返回数据的定义
			url: "/dept/loadDeptManagerLeftTreeJson" // 使用url加载（可与data加载同时存在）
		});
		//监听点击的方法
		dtree.on("node(deptTree)" ,function(obj){
			$("#deptid").val(obj.param.nodeId);
			console.log(obj.param.nodeId); // 点击当前节点传递的参数
		});

		//初始化添加弹出层所在班级的下拉列表
		var classesdeptTree=dtree.renderSelect({
			elem: "#classesdeptTree",
			width: "100%", // 可以在这里指定树的宽度来填满div
			dataStyle: "layuiStyle",  //使用layui风格的数据格式
			dataFormat: "list",  //配置data的风格为list
			response:{message:"msg",statusCode:0},  //修改response中返回数据的定义
			url: "/dept/loadDeptManagerLeftTreeJson" // 使用url加载（可与data加载同时存在）
		});
		//监听点击的方法
		//决定领导框与谁随动
		dtree.on("node(classesdeptTree)" ,function(obj){
			var deptid=obj.param.nodeId;
			//根据班级ID查询当前班级下面的领导列表
			$.get("/user/loadUsersByDeptId?type=4",{deptid:deptid},function(res){
				var users=res.data;
				var dom_mgr=$("#mgr");
				var html="<option value='1' disabled='disabled'>请选择班主任</option>";
				$.each(users,function(index,item){
					html+="<option value='"+item.id+"'>"+item.name+"</option>";
				});
				dom_mgr.html(html);
				//重新渲染
				form.render("select");
			});
		});



		//监听学生名的失去焦点事件
		$("#username").on("blur",function(){
			var username=$(this).val();
			$.get("/user/changeChineseToPinyin",{username:username},function(res){
				$("#loginname").val(res.value);
			})
		});

	});
</script>

</body>
</html>